import grails.plugins.springsecurity.SecurityConfigType



// // locations to search for config files that get merged into the main config
// config files can either be Java properties files or ConfigSlurper scripts

// grails.config.locations = [ "classpath:${appName}-config.properties",
//                             "classpath:${appName}-config.groovy",
//                             "file:${userHome}/.grails/${appName}-config.properties",
//                             "file:${userHome}/.grails/${appName}-config.groovy"]

// if(System.properties["${appName}.config.location"]) {
//    grails.config.locations << "file:" + System.properties["${appName}.config.location"]
// }

grails.project.groupId = appName // change this to alter the default package name and Maven publishing destination
grails.mime.file.extensions = true // enables the parsing of file extensions from URLs into the request format
grails.mime.use.accept.header = false
grails.mime.types = [ html: ['text/html','application/xhtml+xml'],
    xml: ['text/xml', 'application/xml'],
    text: 'text/plain',
    js: 'text/javascript',
    rss: 'application/rss+xml',
    atom: 'application/atom+xml',
    css: 'text/css',
    csv: 'text/csv',
    all: '*/*',
    json: ['application/json','text/json'],
    form: 'application/x-www-form-urlencoded',
    multipartForm: 'multipart/form-data'
]

// URL Mapping Cache Max Size, defaults to 5000
//grails.urlmapping.cache.maxsize = 1000

grails.app.context = "/"
//To allow access from internet.

// The default codec used to encode data with ${}
grails.views.default.codec = "none" // none, html, base64
grails.views.gsp.encoding = "UTF-8"
grails.converters.encoding = "UTF-8"
// enable Sitemesh preprocessing of GSP pages
grails.views.gsp.sitemesh.preprocess = true
// scaffolding templates configuration
grails.scaffolding.templates.domainSuffix = 'Instance'

// Set to false to use the new Grails 1.2 JSONBuilder in the render method
grails.json.legacy.builder = false
// enabled native2ascii conversion of i18n properties files
grails.enable.native2ascii = true
// whether to install the java.util.logging bridge for sl4j. Disable for AppEngine!
grails.logging.jul.usebridge = true
// packages to include in Spring bean scanning
grails.spring.bean.packages = []

// request parameters to mask when logging exceptions
grails.exceptionresolver.params.exclude = ['password']

// set per-environment serverURL stem for creating absolute links
environments {
    production {
        grails.paypal.server = "https://www.sandbox.paypal.com/cgi-bin/webscr"
        grails.paypal.email = "4102s_1317559679_biz@gmail.com"
        grails.serverURL = "http://www.changeme.com"
    }
    development {
        grails.paypal.server = "https://www.sandbox.paypal.com/cgi-bin/webscr"
        grails.paypal.email = "4102s_1317559679_biz@gmail.com"
        grails.serverURL = "http://toonwatch.comp.nus.edu.sg"
        //      ${appName}
        //     Change to toonwatch.zapto.org for complete function for paypal.
    }
    test {
        grails.serverURL = "http://localhost:8080/"
    }

}

// log4j configuration
log4j = {
    // Example of changing the log pattern for the default console
    // appender:
    //
    //appenders {
    //    console name:'stdout', layout:pattern(conversionPattern: '%c{2} %m%n')
    //}

    error  'org.codehaus.groovy.grails.web.servlet',  //  controllers
           'org.codehaus.groovy.grails.web.pages', //  GSP
           'org.codehaus.groovy.grails.web.sitemesh', //  layouts
           'org.codehaus.groovy.grails.web.mapping.filter', // URL mapping
           'org.codehaus.groovy.grails.web.mapping', // URL mapping
           'org.codehaus.groovy.grails.commons', // core / classloading
           'org.codehaus.groovy.grails.plugins', // plugins
           'org.codehaus.groovy.grails.orm.hibernate', // hibernate integration
           'org.springframework',
           'org.hibernate',
           'net.sf.ehcache.hibernate'

    warn   'org.mortbay.log'
}

//password validation
grails.plugins.springsecurity.ui.password.validationRegex = '^.*(?=.*\\d)(?=.*[a-zA-Z])(?=.*[-!@#$%&*()_+=]).*$'

// Added by the Spring Security Core plugin:
grails.plugins.springsecurity.userLookup.userDomainClassName = 'org.toonWatch.User'
grails.plugins.springsecurity.userLookup.authorityJoinClassName = 'org.toonWatch.UserRole'
grails.plugins.springsecurity.authority.className = 'org.toonWatch.Role'


grails.plugins.springsecurity.securityConfigType = SecurityConfigType.InterceptUrlMap
grails.plugins.springsecurity.interceptUrlMap = [
    '/comic/*':               ['IS_AUTHENTICATED_FULLY']
]  

//configure email
grails {
    mail {
        host = "smtp.gmail.com"
        port = 465
        username = "p.sireetorn@gmail.com"
        password = "Birdy_25177879"
        props = ["mail.smtp.auth":"true", 					   
              "mail.smtp.socketFactory.port":"465",
              "mail.smtp.socketFactory.class":"javax.net.ssl.SSLSocketFactory",
              "mail.smtp.socketFactory.fallback":"false"]
    }
}
//


//configure register 
grails.plugins.springsecurity.ui.register.emailFrom = "ToonWatch.com-Team"
grails.plugins.springsecurity.ui.register.emailSubject = 'Welcome to ToonWatch.com'
grails.plugins.springsecurity.ui.register.emailBody = 'Hi $user.name $user.lastname, <br><br> Thank you for registering with ToonWatch.com. <br> To activate your account, please click <a href="$url" target="_blank"> here</a>. <br><br> Cheers,<br> ToonWatch.com Team'

//configure forgot password
grails.plugins.springsecurity.ui.forgotPassword.emailFrom = "ToonWatch.com-Team"
grails.plugins.springsecurity.ui.forgotPassword.emailSubject = 'Reset password on ToonWatch.com'
grails.plugins.springsecurity.ui.forgotPassword.emailBody = 'Hi $user.name $user.lastname, <br><br> You have made a request to change your password. <br> To reset your password, please click <a href="$url" target="_blank"> here</a>.<br> if you did not make the request, please ignore this email. No changes have been made. <br><br> Cheers,<br> ToonWatch.com Team'
//grails.plugins.springsecurity.ui.register.postResetUrl = '/reset'

//implement SSL for login page
//grails.plugins.springsecurity.secureChannel.definition = [
//  '/login/**':  'REQUIRES_SECURE_CHANNEL',   
//   '/':         'REQUIRES_INSECURE_CHANNEL'
//]
